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INTRODUCTION 


Тһе UPLA1 is a low-cost, single-chip microcom- 
puter designed to be used as a universal peripheral 
interface device in а microcomputer system. The 
device is based on a completely self-contained 8-bit 
microcomputer with program memory, data mem- 
ory, CPU, ЏО, event timer, and clock oscillator, in 
a single 40-pin package. A bus interface is included 
which enables the UPI-41 to be used as a peripheral 
controller in MCS-48, MCS-80, MCS-85 and other 
8-bit microcomputer families. The device is de- 
signed for keyboard scanning, printer control, dis- 
play multiplexing and similar applications which 
involve interfacing peripheral devices to microcom- 
puter systems. 


The UPI-41 is fabricated with N-channel MOS tech- 
nology and requires only a single 5-volt supply for 
operation. It has 1K words of program memory 
and 64 words of data memory on-chip. Both ROM 
(8041) and EPROM (8741) versions are available 
and the two are completely pin compatible. The 
instruction set of the UPI-41 is almost identical to 
that of the MCS-48. A single byte data register on 
the UPI-41 interfaces directly to ап 8-bit master 
processor bus to handle asynchronous data transfer 
to and from the master system. A separate 4-bit 
register is used to indicate the status of data trans- 
fer. Two 8-bit TTL-compatible I/O ports plus two 
single-bit test inputs are available. ЏО can be 
expanded further by using the 8243 I/O expander 
device. A separate register in the UPI-41 is used as 
an event counter or interval timer. 


Because it is a complete microcomputer, the 
UPI-41 provides more power and flexibility than 
conventional LSI interface devices. For instance, 
the UPI-41 can be programmed as а peripheral 
interface for any of the low-cost drum or dot 
matrix printers currently on the market. In addi- 
tion to controlling the printer, the UPI-41 can 
handle zero suppression, limit-checking, formatting 
and other computations, thereby unburdening the 
master processor. This type of distributed intelli- 
gence, made possible by the UPI-41, greatly en- 
hances overall system capability while reducing 
cost and development time. 


This application note describes how the UPI-41 can 
be used to implement an interface to a matrix 
printer. The printer chosen is fairly typical of a 
large class of printers which minimize total system 
cost by reducing the mechanical content at the 
expense of more sophisticated electronic require- 
ments. The UPI-41, with its high degree of capabil- 


ity, is ideal for this type of application. It is sug- 
gested that the reader not already familiar with the 
UPI-41 read the “Intel UPI-41 Users Manual” 
before proceeding in this document. 


THE LRC PRINTER 


The LRC Model 7040 printer is a matrix printer 
manufactured by LRC Inc. of Riverton, Wyoming. 
Capable of printing up to 40 columns of alpha- 
numeric information, this printer is mecharically 
simple and should be ideal for a variety of арріїса- 
tions such as point of sale terminals and data 
logging. While this note concentrates on the Model 
7040 printer, the techniques discussed should be 
applicable to a variety of similar printers which are 
currently available. 


The printer (Figure 1) consists of four major sub- 
assemblies, the frame, the print head, the main 
drive, and the paper handling components. The 
frame is an aluminum extrusion which provides a 
suitable base for mounting the various components 
of the printer. The print head consists of seven 
solenoids which each drive stiff wires to impact the 
paper through the inked ribbon. At the solenoid 
end of the print head these wires are arrangec in a 
circular fashion. Where these wires impact the 
printer, however, the wires are arranged n a 
vertical column. To see how this arrangement can 
be used to print alphanumeric characters refer to 
Figure 2. The figure shows a 5 Х 7 matrix of 
"dots". The columns are labeled Cl through C5; 
the rows are labeled as Row 1 through Row 7. 
Each row corresponds to one of the solenoid- 
driven wires. The entire print head assembly is 
moved left to right across the paper so that at T it 
is over Cl, at То И is over C2, and so on. И the 
correct solenoids are activated at each of these 
times (Т1-Т5) then a character can be formed. 
Figure 2 shows the character “A” formed. At Ті 
solenoids one through five were active, at То sole- 
noids four and six were active, and so on until the 
complete character was formed. The complete 
character is formed by choosing the correct pattern 
of active solenoids for each of five instants in time. 


The print head is moved across the paper by the 
main drive. The main drive consists of a 24-pole 
synchronous motor which drives a rotating plastic 
drum. The drum has a spiral groove molded into it. 
A pin attached to the print head rests in this 
groove so that as the drum rotates at a constant 
speed the print head is driven back and forth across 
the paper. Printing is accomplished by controlling 


the activation of the solenoids as the print head is 
driver from left to right across the paper. When the 
end of the print area occurs the spiral groove 
reverses the direction of the head motion. As the 
left-hand edge of the paper is reached a cam 
attached to the drum activates the HOME micro- 
switch and the groove again reverses the motion 
of the head. When the print head is again over the 
print area and travelling in the left to right direc- 
tion the microswitch is deactivated. The printer 
controller uses the trailing edge of the signal gener- 
ated by the microswitch to initiate the printing of 
a new line of information. 


Paper feed is accomplished by a second synchro- 
nous motor which can be activated to feed paper 
through the mechanism. A switch is provided 
whica is activated while the actual line feed is 
occurring. The control logic can use the trailing 


edge of the signal generated by this switch to turn 
off the line feed motor. A version of the printer 
with automatic line feed is available. 


INTERFACE SIGNALS 


The interface signals to the printer consists of a 
pair of wires for each solenoid, a pair of wires for 
each motor (main drive and line feed), a pair of 
wires returning the state of the HOME micro- 
switch, and a pair of wires returning the state of 
the LINEFEED microswitch. 


The solenoids must be driven from a 40 +4 volt 
source. The peak current is approximately 3.64, 
the average current is approximately 0.5А. A 
circuit providing the required drive is shown in 
Figure 3. The output stage, consisting of the 
2N6045 Darlington transistor, the 1N4002 catch- 
ing diode, and the 20-ohm damping resistor, is thc 
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Figure 1. LRC Model 7040 Printer 


one suggested by the manufacturer of the printer. 
Theinput stage is a discrete implementation of a 
DTL gate. Note that the base-emitter junction of 
the 2N6045 will protect the 2N2222A transistor 
from over-voltage on its collector. This circuit has 
several features which are important to the printer 
interface: 


1. All solenoid power (including the power used 
to drive the base of the power transistor) is 
derived from the 40-volt supply. 


2. Disconnecting the drivers from the UPI-41 or 
the loss of the 5-volt supply to the UPI-41 
will result in the solenoids being turned off. 
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Figure 2. 5 x 7 Dot Matrix 
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The first feature of the drivers will minimize the 
impact of the printer and its interface on the 5-volt 
supply of the system. The second feature prevents 
the activation of the solenoids erroneously during 
power on/off cycles or during system che-kout. 
This is an important point since the solenoids will 
be damaged if left activated continuously. (During 
the debug of the design described in this note 
fuses were added to the solenoid drivers to protect 
them from mishap.) 


The two motors can each be driven as shown in 
Figure 4. The Monsanto MCS-6200 is an optically- 
coupled TRIAC which is ideal for driving the small 
synchronous motors in the printer. Coupied with a 
buffer this part provides a simple means of con- 
trolling the motor without sacrificing the isolation 


required for safe and reliable operation. 


Figure 5 shows a UPI-41 used as an interface be- 
tween an Intel® 8085 and an ГВС Model 7040 
printer. The drivers which have already been 
described have been used to interface the TTL 
outputs of the 8741 to the levels required by the 
printer. The two contact closure outputs from the 
printer (PAPERFEED and HOME) have been 
filtered and applied to the TESTO and TESTI 
inputs of the UPI-41. Bit 5 of output port 2 has 
been designated as an interrupt pin which will be 
used to request service from the 8085. 


+40 


47К 
1№914 1М914 1М914 


1м4002 | | 


202 
мом 


4 


Figure 3. Solenoid Driver 
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TIMING 


The relative timing of the interface signals to the 
printer is shown in Figure 6. Actual printing com- 
mences when the main drive switch signal goes into 
the print ready state. This edge indicates that the 
print head is scanning across the paper in the left 
to right direction and that the printer is ready to 
start the actual printing of characters. When this 
edge occurs the UPI-41 must start transmitting 
pulses to each of the seven solenoids. The timing 
for these pulses is shown on the last line of Figure 
6. A pulse of about 400 microseconds is used to 
generate a dot on the paper; a pause of about 900 
microseconds between these pulses satisfies the 
duty cycle restrictions of the solenoids and pro- 
vides a space between dots. Since the printer does 
not provide any feedback to the UPI-41 which 
would indicate the position of the print head, it is 
necessary for the UPI-41 to decide when to fire 
each solenoid based on timing information it main- 
tains internally. The specifications of the printer 
allow 310 milliseconds for the print head to 
traverse the print area. The maximum repetition 
rate at which the solenoids can be fired is once 
every 1.3 milliseconds. The maximum number of 
dots that can be printed in the available print area 
is then 310/1.3 = 238. After the last dot has been 
printed the line feed motor can be activated. The 
motor should remain activated until the line feed 
switch makes the off to on to off transition; this 
takes about 200 milliseconds. After the line feed 
motor is deactivated the next time of interest is 
when the main drive signal goes to the inactive 
state. At this point the printing of a complete 
line, including the necessary line feed, has been 
accomplished and the UPI-41 must prepare itself 
for the reactivation of the main drive switch. 
The activation of this switch will indicate that the 
printing of the next line can commence. 


SOFTWARE 


The software system necessary to drive the LRC 
printer can be thought of as two main parts, each 
with an associated data structure. A block diagram 
of the system is shown in Figure 7. All the items 
shown above the dotted line are associated with 
the BUFFER MANAGER (BMGR) program part. 
All items shown below the dotted line are associ- 
ated with a PRINTER SERVICE ROUTINE (PSR). 
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Figure 6. Printer Timing 
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Figure 7. Software Block Diagram 


The BUFFER MANAGER 15 responsible for all 
interaction with the master processor (i.e., the 
8085 in Figure 5). The data structure associated 
with BMGR is a 40-character buffer which is used 
to store the characters as they are received from 
the master processor. BMGR maintains two 
pointers which are used to access the buffer; these 
pointers are shown as INPUT POINTER and OUT- 
PUT POINTER in the diagram and are imple- 
mented as UPI-41 registers Ro and Ву, respectively. 
The input pointer (INPNT) is kept pointing to the 
last character loaded into the buffer, the output 
pointer (OUTPNT) is kept pointing to the next 
character to be printed. BMGR has two major 
interfaces, the INPUT BUFFER, which is used to 
communicate with the master processor, and the 
register shown in the figure as OUTPUT BUFFER. 
This register, which is implemented with register 
Кз of the UPI-41, is used to communicate with the 
printer service routine (PSR). А character to be 
printed is placed in the output buffer (OBUF). 
When PSR is ready to print the character it moves 
it from OBUF to its own buffer (PBUF) which is 
labeled as PRINT BUFFER in the diagram. After 
the character is moved the output buffer is over- 
written by a predetermined value which indicates 
that PSR has accepted the character. BMGR will 
load a character into the output buffer only if it 
currently is equal to this value. 


The printer service routine utilizes the TIMER to 
keep track of the current position of the print 
head. At the appropriate times it causes the sole- 
noid drivers to be pulsed so that the character 
stream it sees in PBUF is printed. Based on the 
contents of PBUF and the contents of ICNT, 
which indicates the active column of the current 
character, PSR looks up the appropriate column 
data to be printed in the character generator tables. 
This data is stored in the HAMMER BUFFER until 
the precise time that it should be presented to the 
hammer drivers via the I/O bits in PORT 1. ICNT 
and the HAMMER BUFFER are implemented as 
UPI-41 registers 5 and 7, respectively. 


DETAILS OF THE BUFFER MANAGER 


Before BMGR can be discussed in detail, the man- 
ner in which it utilizes the character buffer must 
be understood. Figure 8 shows the operation of the 
buffer while two lines of data are input to the 
UPI-41 and subsequently printed. In order to keep 
the discussion manageable, this figure is drawn as if 
the printer were capable of printing only four 


characters per line. The two lines of characters to 
be printed are: 


ABCD 
1234 


Figure 8. Buffer Operation 


It should be noted that the buffer contains 5 bytes, 
one more than the number of print positions. The 
extra byte is a “phantom address” which, when 
pointed to by the output pointer, indicates that 
the section of BMGR which services the printer 
service routine is inactive. This state must be 
allowed because the actual print operation car not 
begin until the complete line has been input to the 
buffer. If this rule were not enforced, some under- 
run protocol would have to be established to 
handle the situation of the input stream from the 
master processor failing to keep up with the print 
head. 


Figure 8a shows the buffer in its initial state. The 
input pointer is set to the last real position in the 
buffer and the output pointer is set to the phan- 
tom position. Figures 8b through 8f show the 
Operation of the pointers as the characters “А”, 
“В”, “С”, and “D” are loaded. In each case the 


input pointer is incremented to point to the next 
availab с location and then that location is loaded 
with tae character. The position of the output 
pointer is not changed until the last position of the 
buffer has been loaded. When this occurs, the out- 
put pointer is set to point at the first character of 
the buffer. The operation of the pointers thus far 
can be described by the following algorithm: 


INITIAL: 
INPOINT:=BUFFER_MAX; 
OUTPOINT:=BUFFER_MAX+1; 
LOOP: 
IF CHARACTER AVAILABLE THEN 
BEGIN 
INPOINT:=[INPOINT+1) MOD BUFFER, LENGTH: 
BUF FER(INPOINT):=CHARACTER; 
IF INPOINT=BUFFER_MAX THEN OUTPOINT:=BUFFER_MIN; 
END; 
GOTO LOOP; 
END; 


Obviously, if this loop were allowed to continue, 
the buffer would be overwritten by the next line of 
text before the first could be printed. This can be 
prevented by modifying the algorithm as follows: 


LOOP: 
IF CHARACTER. AVAILABLE THEN 
BEGIN 
TEMP:=(INPOINT+1) MOD BUFFER. LENGTH; 
IF ТЕМР<>ООТРОІМТ THEN 
BEGIN 
INPOINT:-TEMP; 
BUFFER(INPOINT}:=CHARACTER; 


IF ANPOINT=BUFFER_MAX THEN OUTPOINT:-BUFFER MIN; 


END; 
END; 
GOTO LOOP; 


This modification will “freeze the action” at Fig- 
ure 8f until the output pointer is incremented. 
When this occurs the input procedure will immedi- 
ately load the input data over the character that 
was just printed (assuming that data is available to 
the procedure at a higher rate than can be printed). 
The defined interface with the printer service rou- 
tine allows a character to be removed from the 
buffer and placed in the output buffer whenever 
the output buffer contains the value placed there 
by the PSR, indicating that it has accepted the 
character that was previously in the output buffer. 
If this value is called EMPTY FLAG then the 
complete buffer handling procedure can be defined 
as follows: 


INITIAL: 
INPOINT:=BUFFER_MAX; 
OUTPOINT:=BUFFER_MAX+1; 
LOOP: 
IF CHARACTER, AVAILABLE THEN 
BEGIN 
TEMP:=(INPOINT+1) MOD BUFFER, LENGTH; 
IF TEMP<>OUTPOINT THEN 
BEGIN 
INPOINT:-TEMP; 
BUFFER(INPOINT):=CHARACTER; 
IF INPOINT=BUFFER_MAX THEN 
OUTPOINT:-BUFFER, MIN; 
END; 
IF OUTPUT. BUFFER-EMPTY FLAG THEN 
BEGIN 
IF OUTPOINT«-BUFFER, MAX THEN 
BEGIN 
OUTPUT. BUFFER :=BUFFER(OUTPOINT); 
OUTPOINT:=OUTPOINT+1; 
END; 
END; 
END; 
GOTO LOOP: 
Examination of Figures 8g through 8r will show 
how this algorithm maintains the buffer. If there is 
an open position and a character is available, it is 
placed in the buffer. When а complete line is in the 
buffer, printing is initialized by setting the output 
pointer to BUFFER_MIN. As the last character of 
a line 15 printed, the output pointer is incremented 
to point at the “phantom location” until the next 
line is completely entered. It should also be noted 
that if the input stream is faster than the print 
operation, then after the last character of a line is 
printed only one character need be input before 
printing can resume (see Figures 81, іп, and п). 
Frame r shows that after all available characters 
have been printed the state of the buffer is the 
same as it is initially. This is obviously a desirable 
feature. 


The flowcharts for the complete BUFFER MANA- 
GER are shown in Figures 9a and 9b. The corre- 
sponding code can be found starting at label 
BMGR of the program listings (see appendix). The 
flowcharts follow the algorithm that has been dis- 
cussed very closely. Some additions have been 
made to implement logic not associated with the 
buffer. The first difference is that when a byte is in 
the input buffer it is tested to determine whether 
it is a command byte or a data character before 
further action is taken. Only two commands are 
recognized; one to set, and one to reset, the in- 
ternal interrupt enable flag. This flag, which 1$ 


implemented as bit zero of PORT2 determines 
whether or not the UPI-41 will assert an interrupt 
to the master processor when it is able to accept 
a new character. Two additional deviations can be 
noted in Figure 9a; the first is that the motor of 
the printer will be turned on whenever a data 
character is received, the second is that if an end of 
line code (1.е., an ASCII line feed) is received, then, 
instead of storing it in the buffer, a mode is en- 
tered which fills the remaining buffer locations 
with space characters. This mode is enabled by bit 
one of PORT2. Note that utilizing otherwise 
unused bits of PORT2 for program status allows 
convenient testing and setting Бу the software and 
also enables external monitoring of the program 
operation. 


VALID 
COMMAND 
7 


NO 


TEMP = 
INCOPT (INPOINT) 


INPOINT-TEMP 


A = INPUT 
BUFFER 


CLR INTERRUPT 


BUFFER(INPOINT) 


-А 
OUTPOINT 
= BUFFER MIN 
чо | 


Figure Эа. Buffer Manager Flowchart 


The last addition to the algorithm can be seen in 
Figure 9b where instead of going directly back to 
the start of the program after servicing the printer, 
a test is made to determine if the interrupt to the 
master processor should be asserted. This interrupt 
is set if the enable bit is set and there is also room 
in the buffer for at least one more character. After 
this test, control is passed back to the beginning 
of BMGR. 
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Figure 9b. Buffer Manager Flowchart 


PRINTER SERVICE ROUTINES 


The Printer Service Routine must convert the char- 
acters given to И by the Buffer Manager intc an 
appropriately timed stream of pulses to the sole- 
noids. Because the PSR is extremely time- 
dependent, it was implemented as an interrupt- 
driven routine which is given control when the 
timer overflow occurs. This allows exact timing 
of the solenoid firings without requiring software 
delay loops. If the timing had been generated by 
such loops, synchronization would have been lost 
when the delay loops were interrupted in order to 
service the master processor. 


На hardware design of a controller for the printer 
were being undertaken, а convenient place to start 
would de to generate a state transition diagram 
which shows all the states that can be entered and 
how control can transfer from state to state. This 
hardware design technique is often useful in soft- 
ware design and was, in fact, used to develop the 
PSR. The state diagram of the PSR is shown in 
Figure 10. A total of eight states are necessary to 
implement the printer control function. Before 
discussing this diagram further, each of these states 
must be defined. 


WPA. The WPA (Wait for Print Area) state is 
the state in which the system waits for 
the input from the printer which indi- 
cates that it is ready to start the actual 
printing of data. 


During the TPA (Test Print Area) 
state the system digitally filters the 
signal from the printer to ensure that 
contact bounce is not causing an er- 
roneous indication that the print area 
has started. 


Transfer to the IPO (Initialize Print 
Operation) state occurs after the posi- 
tioning of the print head over the 
print area has been verified. During 
this state the system initializes itself 
to start printing a line of text. 


The ICOL (Inter Column) state is used 
to time the period between the activa- 
tion of the hammers. During this state 
the space between the dots of the 
characters is generated. 


ТРА: 


ІРО: 


ICOL: 


PCOL: During the PCOL (Print Column) state 
the hammers are energized if the par- 
ticular character being printed re- 
quires a dot in the corresponding posi- 
tion. 


The ICHAR (Inter Character) state 1s 
active between characters on a given 
line. 


During the WFON (Wait for Feed On) 
state the system waits for the asser- 
tion of the feed pulse from the print- 
er. This signal indicates that the 
process of feeding paper is occurring. 


The system remains in the WFOFF 
(Wait for Feed Off) until the feed 
pulse goes inactive. This indicates that 
the required paper teed operation has 
been completed. 


ICHAR: 


WFON: 


WFOFF: 


The state diagram, in addition to defining the 
allowable states, also defines how state to state 
transitions can be made. The general structure of 
this diagram shows that PSR is initiated by the 
occurrence of the timer overflow interrupt. When 
the interrupt occurs the contents of the HAMDAT 
(HAMmer DATa) register are immediately trans- 
ferred to PORT1 which causes the hammer sole- 
noids to be activated. Each of the eight possible 
states sets data into the register which should be 
output at the next timer overflow occurrence and 
starts the timer operating in a mode which will 
result in the main program (BMGR) being inter- 
rupted at the proper time. The following para- 
graphs describe the operation of each of the states 


Figure 10. Print Control State Transition Diagram 
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TPA - TEST PRINT AREA 
ІРО = INITIALIZE PRINT OPERATION 
су ICOL INTER COLUMN DELAY 


PRINT COLUMN 


2 
о 
о 
= 
ШЕТ! 


ICHAR INTER CHARACTER DELAY 
WFON = WAIT FOR PAPER FEED ОМ 

WFOFF = WAIT FOR PAPER FEED OFF 
Coi Sri 

C10 = МОТ (PRINT_AREA) 

C11 = (РНІМТ. AREA)-(FILTEROO) 
C12 = {PRINT_AREA)-(FILTER=0) 

C20 =  (OBUF-EMPTY FLAG) 

C23 =  (OBUFOEMPTY, FLAG) 

C34 = 1 

C43 =  (COL_COUNT(>0) 

C45 =  (COL_COUNT=0) 

C53 хо (ОВЏЕОЕМРТУ FLAG) 

C56 = (ОВУЕ-ЕМРТУ FLAG) 

C66 = (PAPERFEED=OFF) 

C67 = (PAPERFEED=ON) 

C70 = (РАРЕНҒЕЕр-ОМ) 


(PAPERFEED-OFF) 


in detail. Tlie flowcharts of the routines can be 
found in Figure 11. 


The УРА, СРА, and [РО states are all associated 
with the detection of the valid start of the print 
area. The WPA state sets the timer in the event 
count mode so that the edge of the print area 
signal can be detected, the CPA state digitally 
filters this input once it has been detected to 
ensure that noise has not caused a false input, and 
finally, the IPO state initializes the system to start 
the actual printing of data. The flowchart shows 
that the WPA state accomplishes the following 
actions: 


1. Turns off the paper feed motor 

2. Sets the filter count (for the CPA state) 
3. Sets HAMDAT to zero 

4. Sets STATE to one. 


The timer is set to event count with an initial value 
of OFFH. This will cause a timer overflow interrupt 
the next time a negative transition occurs on the 
TESTI input. Since this input is tied to the signal 
from the PRINT AREA switch, this interrupt 
should occur when the start of the print area is 
reached. The WPA state sets the STATE register to 
cause the TPA state to be entered when this inter- 
rupt occurs. Each time the TPA (Test Print Area) 
state is activated the software checks to ensure that 
the print area switch is in the proper state; if it is 
not, then all the actions of state zero are repeated 
(except turning off the motor), since a false start of 
print area has occurred. If the test reveals that the 
print area switch is in the proper state, then the 
filter count is reduced by one and the timer is 
started with an initial value of OFFH, the minimum 
attainable timer increment. The STATE register is 
set to repeat the TPA state unless the filter count 
has reached zero; when this occurs the IPO state is 
selected. The IPO state, which is responsible for 
the initialization of the actual print operation, first 
tests the output buffer register to determine if 
there is any data for it to print. If this test is unsuc- 
cessful the printer main drive motor is turned off, 
the TPA state is reinvoked and the timer is started 
in the event count mode so that it can detect the 
next start of print area. At first glance this seems 
somewhat fruitless since the event required cannot 
happen if the motor is not turning. By referring 
back to Figure 9, however, it can be seen that 
BMGR turns on the motor whenever it has a data 
character from the master computer. The reception 
of a character will always allow the PSR to find the 
next print area. If, when the IPO state makes its 


test, there is data in the output buffer then the 
data is moved to the print buffer and the cutput 
buffer is set to the empty value. After this is ac- 
complished, a counter is set to the number of col- 
umns to be printed per character (seven in this case 
— see comment by ССЕМ label in program listing), 
the STATE register is set to the ICOL state ard the 
timer is set to time the intercolumn time. (The 
intercolumn time is the time that elapses between 
each possible column of the character.) Before 
exiting from this state the first column of data for 
the hammbers is generated by the COLUMN rou- 
tine and placed in the HAMDAT register. 


The three states already discussed set the printer 
up so that it is ready to print. The next three states 
are repeated sequentially until the entire line of 
data has been printed. The ICOL state is probably 
the simplest of the states. When it is invoked the 
hammers have just been fired by the entry into the 
PSR. All that the ICOL state does is to ser the 
timer to time the proper duration of the hammer 
strikes, clear the HAMDAT register, and set the 
STATE register to the PCOL state. The PCOL 
state, only slightly more complicated than the 
ICOL state, first decrements the column court. If 
the end of a character is detected (count equal 
zero), the HAMDAT register is cleared and the 
STATE register is set to invoke the ICHAR state. 
If the end of a character is not detected then the 
COLUMN routine is again used to determine the 
next data to be sent to the hammers and the ICOL 
state is reinvoked. When the ICOL state is active 
two things can happen, depending on whether 
there is more data to print. If there is data in the 
output buffer then a series of actions simila to 
those of the IPO state occur to reinitialize the 
printing of a character; if there is no more data in 
the line then the paper feed motor is turned on, 
HAMDAT is cleared, and the STATE register is set 
to the WFON state. The timer is set for approxi- 
mately one millisecond so that the state. of the 
paper feed switch can be sampled periodically by 
the WFON and WFOFF states. 


The WFON and WFOFF states continue to set the 
timer to the one millisecond sample rate, the 
WFON state reinvokes itself until the paper feed 
switch input is detected and then it invokes the 
WFOFF state. The WFOFF state reinvokes itself 
until the paper feed switch is detected in the off 
state and then invokes the WPA state. The sole 
purpose of the WFON and WFOFF states is to 
ensure that an off to on to off transition occurs on 


the paper feed switch. When this criterion is satis- 
fied tre WPA state is invoked which first turns off 
the paper feed motor and then proceeds to print 
the next line of data. 


CONCLUSION 


The UPI-41 has been shown to be easily capable of 
controlling the LRC matrix printer with no ex- 
ternal logic other than drivers and receivers. The 
program listings which implement the algorithms 
discussed are shown in Appendix A. It should be 
noted that no attempt has been made to minimize 
the amount of code in the program; the emphasis 


was on clarity of operation and ease of implemen- 
tation. A careful programmer should be able to 
significantly reduce the amount of code space 
needed, especially in the printer service routine 
which duplicates much code in each STATE. Even 
with this relatively loose coding the printer control 
function, including the complete character tables, 
easily fit within the memory available in the 
UPI-41. The extra room in memory could be used 
to implement such extra features as tabulation, 
printing prestored messages, or even limited 
graphic capabilities. The power and flexibility of 
the UPI-41 make such features easy to implement. 
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APPENDIX 


1515-11 8648 ASSEMBLER, 91.1 
LRC PRINTER CONTROLLER 7/14/7 


LOC ОВ) SE, SOURCE STATEMENT 
5 
3 ХХХ КА KKK AU AIR IK IKI KKK N KN KNN KAKAK КК КК e Ae e de de de de TE ЖЖЖ 
4 . 
5 ; UPI-41 LRC PRINTER CONTROLLER 
7; THIS PROGRAM IMPLEMENTS THE CONTROL OF THE 
8 ; ГАС PRINTER WITH THE UPI-41. DATA IS INPUT TO THE 
9 ; UPI-41 AS SIX BIT ASCII. COMMANDS ARE PROVIDED 
10; ТО ENABLE OR DISABLE THE GENERATION OF AN 
11; INTERRUPT WHEN THE UNIT І 
12; FOR ANOTHER BATA CHARACTER, THE INTERRUPT IS ENABLED 
13; BY OUTPUTING @ЗН TO THE CONTROL CHANNEL AND DISABLED 
14; BY OUTPUTING Q2H, WHEN ENABLED THE INTERRUPT 
15 ; IMPLEMENTED AS А POSITIVE GOING EDGE ОМ P25, 
17 ; NOTE: A PL/M LIKE LANGUAGE WAS USED ТО COMMENT 
18; THIS PROGRAM. NO COMPILER EXISTS FOR THE UPI-41, 
19 ; THE COMMENTS WERE "HAND COMPILED" INTO UPI-41 
20 ; ASSEMBLY LANGUAGE, 
22 LH HE AI D КЕ ЖКХ 
23 
24 
26 :* ДАДА О AR АХАЖ A KNN RARA RARA Ad 
27 
28 ; REGISTER ASSIGNMENTS 
22 F F E E e Ae ААА NKANKA de He he e e ИК КАК КАКА КАКА КАКИХ) 
ђ 
0247 33 HAMDAT EQU R7 
0006 34 STATE EGU R6 
0005 35 ІСМТ R5 
0004 36 PBUF E R4 
0003 37 OBUF EQU БЕ 
0002 38 TESTR R2 
0001 39 OUTPNT EQU ві 
0008 40 INPNT ВОЮ RO 
42 
8 Ны ыы ады d АЯ 
45 : 
46 ; TIMER EQUATES 
43 FFC 
49 
Q0AQ 50 TICK EQU 160 
FFFE 5] THON -320/TICK 
FFFD 52 THOFF Ú -480/TICK 
FFF8 53 TINTER EQU -1280/ТІСК 
FFFA 54 TLFEED EQU -1000/TICK 
0004 55 FILIV 0 648 /ТІСК 
58 Fr . A KAAKA 
59 
60 ; PROGRAM MASKS 
91 (OSE SCSI EOC ADI I ыы ыы 
63 
BOEF 64 EMTFLG EQU QFFH 
0007 65 ІМАХ 0 07H 
007€ 66 PFEED 0 7FH 
OOBE 67 MOTON ERU ОВЕН 
0001 68 INTENA EQU 01H 
0002 69 FMODE ЕС) 02H 
дОдА 78 EOL EQU ЙАН 
0021 71 EXCLAIM 9218 
0020 72 SPACE FO 20H 
0020 73 E EQU 20H 
0018 74 QPIMÍN EQU 18H 
0018 75 BIN  EQU 184 
00ЗЕ 76 В EQU 3FH 
77 
78 
79 $ EJECT 
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1416 
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SOURCE STATEMENT 


„ K ke de ke e k de k de ke ke k Ae k dek dek de k de k Ae de de de de de КАК k e ke e he e ke e e k ke ke ke k e k de k ke ke ke ke ke de kke ke ke h k kk k k КК 


—— eS 


RESET: 


START OF PROGRAM 


ORG 
CALL 
CALL 


EN 
JMP 


„R K XX XTX de e k Ae ke Ae de e e Ae e e e Ae he e KER KANNAN KAA NAKA NA RÉ 


; INITIALIZE; 
; INITIALIZE AND GO TO 
; BMGR 


; CODE MUST END AT LOC 6 


„ КККК КККК АКИКА КИА NXT AN NN NA NN NX XX AXN XXX XX XX RX XK RRR RRR TRR NX 2 


i 
i 
H 
H 
H 
TISR: 


СВАЗЕ: 


CASE : 


CASEL: 


START OF INTERRUPT DRIVEN STATE MACHINE 


ekkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkikkkkkkkkkákkkkkkikkkkkkkkkkkkkkkkkkkkki 


; DO; 
; HAMMERS=HAMMERSDAT ; 
; DO CASE STATE; 
авн 
Pl,A 
A,STATE 
A, #CBASE 
A 
CASE 
CASE1 
CASE2 
CASE3 
CASE4 
CASES 
САЗЕб 
CASE? 
, 
; DO; /*CASE 0. FEEDING LINE */ 
; PAPERSFEEDSOFF 
; STATE=] ; 
; ICNT=FILTV 
; WAIT (PRINTSAREA) ; ; 
HAMMERSDATÀ 
; END; /* END OF CÁSE @ */ 
P2 + (NOT PFEED) 
STÁTE 
ICNT P 
A, #- 
ТА 
CNT 
А, #0 
А,НАМРАТ 
; DO; /* CASEl,TESTING FOR PRINT AREA */ 
; ТЕ Т@=1 THEN 
; pner 
; FILTV; 
; WAIT (PRINTAREA) ; 
Г HAMMERSDATA= ; 
, , 
C1ELS 
STATE, #1 
ICNT $FILTV 
, 
t 
А, #2 
CÍEND 
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LOC OBJ SEQ SOURCE STATEMENT 
ELSE 


з DO; 
159 | ICNTSIC 
160 ; IF ICNT-Ó АТ AMEN STATE-2 ELSE STATE-1; 
161 ; TIME (-1); 
152 ; c DAMMERSDÁTA- =O; 
0032 BEQ2 164 ClELS: MOV STATE, $2. 
0034 ED38 165 DJNZ ICN, CI LA 
9936 ВЕЙ1 166 MOV STATE, #1 
0038 23FF 167 CILA: MOV 4- 
003A 168 MOV T, 
003B 169 STRT 
003С 2300 170 MOV А, #0 
; END; /*END OF CASEl * 
базе 2F 172 CIEND: ХСН A,BAMDAT f MEA 
003 93 173 RETR 
174 
175 
176 ; DO; /*CASE 2, INITIALIZE PRINT OPERATION */ 
177 ; IF ОВОР<>ЕМРТУЗЕГАС THEN 
178 ; 507 
179 H ME (HAMMERSOFF) ; 
180 H PBUFLOBUEs 
181 $ OBUF=EMPTYSFLAG; 
182 ; T= : 
183 ; STATE=3; 
184 7 HAMMERSDATA=C@LUMN (РВОЕ, 1); 
185 ; END; 
0040 ЕВ 186 CASE2: MOV A, OBUF 
0041 D3FF 187 XRL A, #EMTFLG 
0023 C655 188 JZ COELS 
0025 ЭЗЕР 189 MOV А, #THOFF 
0047 62 198 MOV ТА 
0048 55 191 STRT Т 
0049 ЕВ 192 MOV А,ОВОЕ 
004A АС 193 MOV РВОЕ,А 
00 48 BBEE 194 MOV OBUF + FEMTFLG 
QUAD Врӣ7 195 MOV ICNT, ФІМАХ 
004Е ВЕЙЗ 196 МОУ STATE, #3 
0951 54ЕЙ 197 CALL 
0053 045Е 198 JMP C2END 
199 ; ELSE го; 
200 ; STATÉ 
29 1 : WAIT BAIT (PRÍNTSAREA) ; ; 
203 ; HAMMERSDATA=0 ; 
0055 ВЕФІ 205 C2ELS: MOV STATE, #1 
0057 23FF 206 MOV A, 
0059 62 207 MOV т, 
965 45 208 STRT С 
005в 8A40 209 ORL Б2 gnor MOTON 
6055 2300 210 MOV Art 
211 ; END; /*END OF CASE 2 */ 
QUSE 2F 212 C2END: ХСН A, BAMDAT 
0060 93 213 R 
215 ; /*CASE 3, HAMMER OFF CYCLE */ 
216 ; PO TE HAMMERSON) ; 
217 ; DATA-0; 
218 ; STATE= 
219 ; END; /*END OF CASE 3 */ 
9261 23FE 220 CASE3: MOV А, #THON 
0263 62 21 MOV É 
0264 55 222 STRT 
0265 2300 223 MOV 
0067 BEG4 224 MOV STATE, #4 
0069 2Е 225 ХСН A, HAMDAT 
006А 93 226 
227 $ EJECT 
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SOURCE STATEMENT 


; DO; /*CASE 4,PRINTING COL I OF CHAR */ 
; TIME (HAMMERSOFF) ; 
CASE4: MOV А, #THOFF 
MOV Т.А 
STRT T 
; 85. El; THEN 
Н DO; pg: 
; HAMMERSDATA=0 ; 
; END 
DINZ ICNT,C4ELS 
MOV STATE, #5 
MOV А, #0 
JMP C4END 
ELSE DO; 
STATE=3 


HAMMERSDATA=COLUMN (PBUF, І); 


ч.ч..... 


H 


C4ELS: MOV STATE, #3 


CALL COLUMN 
9 Н END; /* END OF CASE 4 */ 
2 o C4END: ДЕН A,BAMDAT 


R 
; DO; /*CASE 5 INTERCHARACTER SPACE */ 
; Ilg INR 

CASES: MOV A, #TINTER 
5 MOV Т.А 
SIRT T 

; IF OBUFC>EMPTYSFLAG THEN 
; ' PBUF=OBUF; 
: OBUF=EMPTYSFLAG; 
; STATE-3; 
; 


HAMMERSLATA=COLUMN (PBUF , І); 


. 


U 


MOV 4 
MOV STATE, #3 
CALL СОШ) 
JMP CSEND 
4 ELSE DO 
; TIME ( (LINESPRED) ; 
; PAPERSFEED-ON; 
; STATE=6 ; 
; DATA-0; 
0 ; END; 
CSELS: MOV À, #TLFEED 
2 MOV Т,А 
STRT L 
ANL #PFEED 
MOV SE, #6 
MOV 
; END; /* END OF CASE 5*/ 
CSEND: ХСН A,HAMDAT 
RETR 
$ EJECT 
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LOC OBJ 


0100 

010) 0647 
0102 7636 
0104 ЗАВЕ 


0106 F8. 
0107 3470 


NN 
© 


WW WI LL GLO CO LL CO CO UI LI СӘ ТҮЗГҮЧ УЗ CO LAA WWI GO GU I ТҮЗ СО СА) WII) WI Go WILY) LOCO LAAL UI U CO CI WI) WLW LO WLW CO LA WILD WI WWW LO COLOLOLOLOCOCO LA LO NONO 
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SOURCE STATEMENT 


DO; /*CASE 6,WAITING FOR FEED ON */ 
TIME (LINESPEED) ; 


i 
; ТЕР S=1 Т 
; ! STATE-7; 
CASE6: MOV А, #TLFEED 
MOV T, 
STRT 
JNTÓ | C6ELS 
MOV STATE, #7 
JMP END 
; ELSE DO: 
; STATE=6; 
; END; 
C6ELS: MOV STATE, #6 
і END O O OF 6 * 
; ; END ОР "Diss 
C6END: MOV A, 40 : / 
ХСН А, HAMDAT 
RETR 
; WAITING FOR FEED OFF * 
; DO: MET SE ; / 
2 ТЕ PFS THEN 
; DO; 
; 5ТАТЕ-й; 
| H END ; 
CASE7: MOV A, #TLFEED 
MOV Т,А 
STRT T 
Јтд C7ELS 
MOV STATE, #0 
JMP СТЕ 
$ ELSE DO; 
; 5 ¡STATÉ= =7; 
; BAMMERSDA 


END; /*END OF “thse 7 */ 


C7END: MOV 
XCH А, HAMDAT 


C7ELS: MOV STATE, #7 
A, #0 
; END; /* END OF CASE ВГОСК */ 


kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 
; BMGR 


i 
; THIS SEGMENT CONTROLS THE HANDSHAKING BETWEEN THE 
; CONTROLLER AND THE MASTER PROCESSOR. 


> RH AR HR AR LARREA КАКА RARA RARA AAA RA RRA RRA RRA RRA RARA RRA IIR RARA RRA RARA k k 
; /BMGR-BUFFER MANAGER*/ 


DO; 
ТЕ IBF=FULL THEN 
ip TYPE=DATA THEN 


DO; 
MOTOR=ON ; 
TEMP=INCOPT (INPNT) ; 


—— x 2 mR ~ a 


ORG 1008 


BMR: ЈАВЕ ВВРЕТ 
JFl BBCMD 
ANL P2 , #MOTON 
MOV А, INPNT 
CALL INCQPT 
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SOURCE STATEMENT 
i5 TEMP<>OUTSPOINT THEN 


INSPOINT=TEMP ; 
IF FILLSMODE=ON THEN 


DO; 
TEMP-SPACE; 

LSE DO; 
TEMP-INPUTSBUFFER; 
INTERRUPT=OFF; 

END; 
iE TEMP-EOL THEN 


" FILLSMODE-ON; 
TEMP=S PACE; 


END 

IF TEMP-CONTROLSCODE THEN TEMP-'!'; 
BUFFER(INSPOINT)=TEMP AND ЙЗЕН; 

IF INSPOINT-BUFFERSMAX THEN 


ме че 9e o ме — sa e 9a чө mo a se seo emo че ме че УУ 


DO; 
FILLSMODE=OFF; 
OUTS POINT=BUFFERSMIN; 
END; 
END; 
BBLl: XI. A,OUTPNT 
JZ BBPRT 
A, QUTPNT 
MOV INPNT,A 
ТА A,P2 
JBl FILL 
ANL 55 PROT (EXREQ) 
JMP L 
FILL: МОУ A, #SPACE 
BBLIA: ХЫ, A, #EOL 
JNZ BBL1B 
ORL P2 fEMODE 
JMP BBI IC 
BBLIB: ХЕ, А, БОБ 
JB6 BBLIC 
JB5 ВВС 
MOV А, #EXCLAIM 
BBLIC: АМ, A, #03FH 
MOV GÍNPNT,A 
MOV A, INPNT 
XRL ; 
JNZ BBPRT 
ANL P2,#NOT FMODE 
MOV OUTPNT, #BMIN 
JMP BBPRT 
; ELSE DO; /*TYPE IS COMMAND*/ 
; INTERRUPT=OFE; 
; IF (PORTO AND 3)=2 THEN INTENA=OFF; 
; IF(PORT@ AND 3)=3 THEN INTENA=ON; 
; ЕМО; 
BBCMD: IN BB 
ANL P2, #МОТ (EXREQ) 
ANL A, 43 
JBI BBL2 
JMP BBPRT 
BBL2: 280 BBL3 
ANL P2,#NOT INTENA 
JMP PRT 
ввіз: ОВ P2,#INTENA 
$ EJECT 
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OBJ SOURCE STATEMENT 


2 
e 


IP OBUF-EMPTYSFLAG AND (OUTSPOINT<>BMIN OR STATE: 
55 OUTSPOINT<=BUFFERSMAX THEN 

"ОВОРеВІМ (OUTSPOINT) ; 

Қанға ; 


7 
7 


ы» Eo >» > > и 
oD Bb LIL CU CU 
> LU OOO 


END: 
ЕВ 445 BBPRT: MOV А,ОВОР 
D3FF 446 XRL A, FEMTFLG 
965Е 447 JNZ BÍ 
F9 448 MOV A,QUTPNT 
D318 449 XRL A, #QPTMIN 
9658 450 JNZ A 
FE 451 MOV A, STATE 
ОЗЕР 452 ADD А,#-3 
F258 453 JB7 BÉPRTA 
245E 454 JMP BIN T 
F9 455 BBPRTA: MOV 250 
D25E 456 JB6 BINT 
Fl 457 MOV QOUTPNT 
AB 458 MOV OBUE A 
19 459 INC 80 T5, 
460 7 TEMP-INCQPT (INPNT) ; 
461 ; IP ТЕМР<>ООТ$РОТМТ THEN 
463 : ТЕ INTENA-ON AND FMODE=OFF THEN INTERRUPT-ON; 
464 5 END; 
465 ; END; 
466 : END 
467 
F8 468 BINT: MOV А, INPNT 
3470 469 CALL INCQPT 
470 XRL A,OUTPNT 
C600 471 JZ B 
472 BINTA: 
дА 473 ІМ А,Р2 
474 CPL 
1280 475 280 BMGR 
326C 476 JBL SETINT 
ET ^ 
SETINT: Р. 
2400 479 JMP BMGR 
180 
481 
482 
483 
484 
485 
486 
481 Я ТЕ INCQPT (A, CARRY) ; 
ГА 
489 ; “А-А MOD BUFFER LENGTH+BUFFER MIN; 
490 ; IF A-BUFFER ! MIN THEN CARRY=17 
0301 10) неон ADD. ЗА. 7 77 
D275 493 JB6 ADJUST 
83 494 RET 
2318 495 ADJUST: MOV A, #QPIMIN 
A7 496 CPL E 
83 497 RET 
499 
500 ; PROCEDURE INIT; 
501 ; DO; 
502 7 OBUF=EMPTYSFLA( 
593 ; S 
504 % INSPOINT=BUFFERSMAX ; 
595 ;  MOTOR=OFF; 
596 Н PAPERSF EED-OFF; 
587 ; FILLSMODÉ=OFF : 
508 ; INTERRUPTSMASK-OFF; 
509 ; — BUSSBUFFER-0; 
510 ; END; 
BBFF 511 INIT: MOV OBUF, #EMTFLG 
8940 512 MOV OUTPNT , #BMAX+1 
ВЕЗЕ 513 MOV INPNT, $ 
2320 514 MOV А,#ЙЕЙН 
ЗА 515 OUTIL P27 A 
2 516 IN À, DBB 
83 517 БЕТ 
518 
519 
520 
521 
522 
523 
524 $ EJECT 


LOC OBJ 


02E0 
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SOURCE STATEMENT 
X XXX XXX XX XXX XXX TAX * N N * N A K* K ** K KKK K* ** KN KR K K K K K* K* K * 


COLUMN IS CALLED WITH ТСМТ EOL TO THE CURRENT COLUMN NUMBER 
AND PBUFF EQL TO THE CHARACTER TO BE CONVERTED, 

COLUMN RETURNS THE APPROPRIATE COLUMN OF DATA FROM THE 
CHARACTER GENERATER TABLE. COLUMN 15 LOCATED IN PAGE 2 
FOLLOWING THE FIRST HALF OF THE TABLE. 


kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk*kkk 


ORG 2ЕВН 
PROCEDURE COLUMN (PRINTSBUFFER, ICNT) ; 


' FLAGG=NOT PRINTSBUFFER [5]; 
PRINTSBUFFER [5] = 


, 
; TEMP=7* (PBUF+1 nr 
; iP FLAGÓ-OFF THEN 
; ТЕМР=МРЗ (TEMP) ; 
; LERINISBÜPFERIB| = =1; 
ГД 
2 ENDA po 
: ТЕНОР МР? (TEMP) ; 
4 U 
: END; 
COLUMN: MOV A,PBUF 

CLR ЕЙ 

JB5 NOSET 

CPL FÜ 

NOSET: ANL А, #01ЕН 

MOV PBUF,A 

RL À 

RL A 

RL А 

СРЬ А 

ADD A,PBUF 

ADD А, ICNT 

СРЬ А 

ADD А, #7 

ЈЕЙ PAG2 

MOVP3 А, Gn 

ХСН A,PBUF 

ORL A, #20H 

XCH À, PBUF 


ВЕ 
РАС2: МОУР А, @А 
ВЕТ 


ле че ме ——————ꝛ——.—' о — 


* * K K kkk kkk К khkk X kkk K XX X k k XXX kk kkk kk XX XXX XTX XK k k kkk k kk NN X XN XTX XN XK К 


CHARACTER GENERATER TABLES, ~ 

THE FIRST HALF OF THESE TABLES IS IN PAGE 2. FOLLOWING THIS HALF 
IS THE COLUMN SUBROUTINE, THE SECOND HALF OF THE TABLE IS 

IN PAGE 3, THE PLACEMENT OF THESE TABLES IS TO TAKE 

ADVANTAGE OF THE МС5-41 MOVP AND MOVP3 INSTRUCTIONS. 


THE CHARACTERS ARE FORMED BY A SEVEN BY SEVEN MATRIX 
OF DOTS. BACH DOT POSITION CORRESPONDS 

TO ONE HALF THE NORMAL DOT SPACING OF THE LRC PRINTER, 

TO PREVENT EXCEEDING THE "BANDWIDTH" OF THE SOLENOIDS 

THE CHARACTERS ARE FORMED SO THAT THE SAME SOLENOID IS 

NOT ENERGIZED TWICE IN SUCCESSION, CONSTRUCTING THE 

TABLE IN THIS MANNER ALLOWS THE FORMATION OF А CHARACTER IN ONLY 
4 PRINT COLUMNS SINCE THREE OF THE DOTS WILL APPEAR BETWEEN 
NORMAL COLUMN POSITIONS. 


THE COMMENT FIELD OF THE TABLE SHOWS THE BIT PATTERN OF THE 


CHARACTERS. THE SPACING OF THE PRINTER CHARACTERS CAUSES 
DISTORTION OF THE CHARACTERS BUT THE PATTERN IS STILL DISCERNABLE, 


РОА HK K КИК Ж ККИ КК RK KKK HI KR IKK I RIT RK IKE ERIK IE RK * 
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DB 7ЕН ; * * * * ** ; [В] 
DD 00H P 

DB 48H ; хо * 

DB 00H ; 

DB 94H ; * 

DB 4AH y X * ж 

DB 31H ;* ** 

DB 32H A ЖЖ ; [5] 
DB 49H уж * * 

DB 00H ; 

DB 49H жож k 

DB 00H Я 

рв 49H іа X 

DB 26H ; жж * 

DB 40H * ; [Т] 
DB 20 ; 2 
DB 40H ; * 

DB 3FH : & * * * * * 

DB 40H ; * 

DB 00H ; 

DB 40H ; * 

DB 7СН ро eek ; [0] 
DB 02H ; Ж 

DB 91H рж 

DB 29H ; 

DB ЙІН ; * 

DB 02H р * 

DB 7CH F *** 

DB 78H ; жижи : [V] 
DB 04H 2% 

DB 02H ; Ж 

DB ЙІН ; * 

DB 02H br 

DB 04H 7 * 

DB 78H ; жижи 

DB 7ЕН . & * KN * * Я [W] 
DB 018 ; * 

DB 02H ; > 

DB OCH ро ** 

DB 028 $i АЖ 

DB 01H ; * 

DB 7EH ро ARA 

DB 41H ; X * ; IXI 
DB 22H рож ж 

рв 14H ; X * 

DB 08H ; * 

DB 14H р + X 

DB 22H ро * ж 

DB 41H ; * * 

DB 49H ; * ; [X] 
DB 20H ; * 

DB 19H ; * 

DB бЕН ; хх» 

DB 100 * 

DB 200 ; * 

DB 48H ; * 

EJECT 
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БЕО SOURCE STATEMENT 
818 DB 41H ра * : [2] 
819 DB 02H ; * 

820 DB 45H AR X 

821 DB Ж ; Ж 

822 DB 51H РЕНЕ 

823 DB 20H ; * 

824 DB 41н Бары * 

825 

826 DB 7FH pO OK ke ; [dil 
827 DB 00H ; 

828 DB 41H ; * * 

829 DB 00H ; 

836 DB 41H ; * * 

831 DB 00H ; 

832 DB 41H ; X * 

833 

834 DB 40H ; * : N 
835 DB 20H ; * 

836 DB 10H ; * 

837 DB 08H ; * 

838 DB 04H 1 * 

839 DB 02H ; * 

840 DB 01H ; * 

841 

842 DB 41H ; * * : 0) 
843 DB 08H ; 

844 DB 41H ; * * 

845 DB 00H ; 

846 DB 41H P * 

847 DB 00H ; 

848 DB 7FH porke 

849 

858 DB 00H ; ; [UA] 
851 DB 04H 71 * 

852 DB 08H ; * 

853 DB 10H ; * 

854 DB 08H ; * 

855 DB 04H 71 * 

856 DB вен ; 

857 

858 DB 01H 1 * : (.] 
859 DB 00H ; 

860 DB ЙІН ; * 

861 DB 00H ; 

862 DB ЙІН ; * 

863 DB 90 ; 

864 DB 01H ; * 

865 

866 

867 

868 

869 ХХХ ek eek АВА EK EKER EK ККИ KKK Ж ЖИ КК KAAKA NAK KAKAK ТАЈ 
879 ; 

87 ; START OF SECOND HALF OF CGEN TABLE 

873 CCC 
874 

875 ORG 300 

876 

877 

878 DB 90 ; : Р) 
879 DB QOH ; 

880 DB 00H ; 

881 DB 90H ; 

882 DB 00H ; 

883 DB 00H ; 

884 DB 00H ; 

885 

886 DB дон ; : [9 
887 DB 00H ; 

888 DB б ; 

889 DB 7DH ; X kk 

890 DB 00H ; 

891 DB 00H ; 

892 DB 00H ; 

893 

894 $ EJECT 
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; [$] 
: 
: 
i ; Is] 
i 
; LS) 
; 
; р ІЗ 
; 
; 
Н 
; 
; 
; 
DB 1CH By LUNAR ; ТО 
DB 22H р X * 
DB 41H : * N 
DB 20H 2 
DB 90H ; 
DB 09H : 
DB 00H р 
DB 008 : : D] 
DB 00H ; 
DB 90H 2 
DB 00H 7 
DB 41H ; * ж 
DB 22H ; X X 
DB 1CH ; * 
DB 49H s X X ж ; [*] 
DR ДД pm d 
DB 1CH р XX 
DB 77H ) ** ЖЖЖ 
рв 1CH LL 
DB 22H роко ж 
DB 49H Коко ж 
DB 08H ; * ; [+] 
DB 08H ; * 
DB 08H ; * 
DB 3EH 5 *** 
DB 08H ; * 
DB 08H ; * 
DB 08H ; * 
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DB дон ; 

DB ден Н 

рв 01H ; * 

DB 06H әл ЖЖ 

DB вон H 

DB 00H H 

DB 04H n * х [-] 
DB 04H ж ж 

DB 04H : ж 

DB 04H H x 

DB 04H 2 * 

DB ДАН ; * 

DB 04H ; * 

DB дан і : l.] 
DB 00H ; 

DB 00H ; 

DB 0 H 

DB 00H H 

DB 9011 ; 

DB 00H ; 

EX Z 
ош i LE 
DB ÿ4H ; * 

DB 08H 2 Е 

DB 10H ; * 

DB 28H ; * 

DB 40H ; * 

DB 1DH ; * RR ; [0] 
DB 22H ; ко X 

DB 45H 7 * * * 

DB 08H P N 

DB 51H pote CAN 

DB 22H EE NS 

DB 5CH 71 ** * 

DB 00H ; ; [1] 
DB 21H рк ж 

DB 40H ; * 

DB ЗЕН ; PARAR 

DB 00H ; 

DB ü ; * 

DB 000 ; 

DB 23H ;** * : [21 
DB 44H ; х * 

DB 91H 3 * 

DB 48H ; * * 

DB ЙІН пеи 

рв 48H ; хо ж 

DB 31H 2% ЖЖ 

DB 42H gi * * ; BI 
DB 01H px 

DB 50H ; * * 

DB g р 

DB 50H р * * 

DB 29H ра * * 

DB 46H ро * * 

EJECT 
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5 [>] 


DB 004 R 

DB 41H 3 * * 
DB 22H $ Ж. Ж 
ОВ 14H 2 ж * 
DB 08H ; * 

ОВ 00h H 

DB 00 ; : [2] 
DB 28H ; * 
DB 49H ; * 
DB 05H ; * * 

DB 48H р * * 
DB 30H : жк 
ОВ вон ; 

END 
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Glen White Associates 
P.O Box 1104 
Lynchburg 24505 

Tel: (804) 384-6920 


WASHINGTON 


E.S./Chase Co. 
Р.О. Box 80903 
Seattle 98108 

Tel: (206) 762-482< 
Тих: 910-444-2298 


CANADA 

Intel Corp. 

70 Chamberlain Ave. 
Ottawa, Ontario K1S 1V9 
Tel: (613) 232-8576 
TELEX: 053-4419 
Mullitek, Inc * 

4 Barran Street 

Ottawa. Ontario K2J 192 
Tel: (613) 825-4553 
TELEX 053-4585 


GERMANY 

Intel Semiconductcr GmbH" 
Seidlslrasse 27 

8000 Muenchen 2 

Tel. (089) 55 81 41 

TELEX: 523 177 


Intel Semiconductor GmbH 
Abraham Lincoln Stiasse 30 
6200 Wiesbaden 1 

Tel: (06121) 74855 

TELEX: 04186183 

Intel Semiconductor GmbH 
D-7000 Stutigart 80 
Ernslhaldenstrasse 17 

Tel: (0711) 7351508 
TELEX: 7255346 

intel Semiconductor GmbH 
Wiesenweq 26 

D-6272 Niederhausen 

Tel: (06127) 2314 


SPAIN 

Intertace 

Ronda San Pedro 22 
Barcelona 10 

Tel. 301 78 51 


SWEDEN 

Nordisk Electronik AB 
Fack 

S-10380 Stockholm 7 
Tel: (08) 248340 
TELEX: 10547 
SWITZERLAND 
Industrade AG 
Gemsenstrasse 2 
Postcheck 80 - 21°90 
CH-8021 Zurich 

Tel: (01) 60 22 30 
TELEX: 56788 


UNITED KINGDOM 
Rapid Recall, Ltd 
11-15 Betterton Slreet 
Drury Lane 

London WC2H 983 
Tel: (01) 379-6741 
TELEX 28752 

G.E C. Semiconductors Ltd 
Easl Lane 

Wembley НАЗ 7PP 
Middlesex 

Tel: (01) 904-9303 
TELEX. 923429 
Jermyn Industries 
Vestry Eslate 
Sevenoaks. Ken! 

Tel, (0732) 50144 
TELEX. 95142 


*Field Application Location 
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